<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script>
        // 冒泡排序的原理：
        // // 每一大轮都是相邻两个元素依次进行交换，知道最后一轮结束元素变成正确的顺序

        // 一共需要交换的趟数用外层for循环
        // 例如5个数据需要交换4趟，所以交换的趟数等于数组长度减去1：length - 1；

        // 每一趟需要交换的次数用里层for循环
        // 第一趟：4次
        // 第二趟：3次
        // 第三趟：2次
        // 第四趟：1次


        // 每趟的交换次数是 数组下标从0开始所以 是 length - i - 1 例如第一趟 5 - 0 - 1=4 0就是索引号
        var arr = [12, 344, 34, 0, -4];
        for (var i = 0; i < arr.length - 1; i++) {
            for (var j = 0; j < arr.length - i - 1; j++) {
                if (arr[j] > arr[j + 1]) {
                    var temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
        }
        console.log(arr);



    </script>
</head>

<body>

</body>

</html>